<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box {
            width: 100px;
            height: 100px;
        }
        .box1 {
            background-color: lightblue;
            margin-bottom: 50px; /* 下外边距 */
            display: inline-block; /* 解决外边距塌陷问题 */
        }
        .box2 {
            background-color: lightcoral;
            margin-top: 30px; /* 上外边距 */
        }

        .wrap {
            background-color: lightgray;
            width: 200px;
            height: 200px;
            margin-top: 20px;
            /* overflow: hidden; */
            border: 1px solid transparent;
        }
        .item {
            background-color: lightgreen;
            width: 100px;
            height: 100px;
            margin-top: 50px; /* 上外边距 */
        }
    </style>
</head>
<body>
    <!-- margin 的上下外边距塌陷问题：指两个兄弟元素
    在垂直方向上的外边距发生合并现象，即取较大值作为最终的外边距。 
    解决方案：
    1.给任何一个元素加上display：inline-block;
    2.把外边距加到一个元素上
    3.给一个元素把外边距改为内边距
    4.设置overflow属性
    5.给父元素加透明边框
    -->



    <div class="box box1"></div>
    <div class="box box2"></div>



    <div class="wrap">
        <div class="item">

        </div>
    </div>
</body>
</html>